<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title></title>
    <script type="text/javascript" src="./js/vue.js"></script>
</head>
<body>
    <!-- 准备好一个容器 -->
    <div id="root">
        <form @submit.prevent="demo">
            账号:<input type="text" v-model="userInfo.account"><br><br>
            密码:<input type="text" v-model="userInfo.passworf"><br><br>
            <!-- 这里的 input的number 是限制只有数字输入。 vue里面的number 是不接受空格 但是名字里的接受 -->
            年龄:<input type="number" v-model.number="userInfo.age"><br><br>

            性别:
            <!-- 使用name 就是说明是同一组 ，可以进行单选。 -->
            <!-- 这里不是用户输入 所以没办法接受用户输入的值 ，这边我们自己写value -->
            男<input type="radio" name="sex" v-model="userInfo.sex" value="male">
            女<input type="radio" name="sex" v-model="userInfo.sex" value="female"><br><br>

            爱好:
            <!-- 这种多选的用数组来接受数据。如果用字符串接受的是checked的值 返回的布尔值。一个true 其他两个都true 然后就一起选择了-->
            <!-- 所以单选用字符串，多选用数组 -->
            学习:<input type="checkbox" v-model="userInfo.hobby" value="study">
            打游戏:<input type="checkbox" v-model="userInfo.hobby" value="game">
            吃饭:<input type="checkbox" v-model="userInfo.hobby" value="eat">
            <br><br>
            
            所属校区
            <!-- 记得要写value 因为接受的是value值 -->
            <select v-model="userInfo.city">
                <option value="">请选择校区</option>
                <option value="beijing">北京</option>
                <option value="wuhan">武汉</option>
                <option value="shenzhen">深圳</option>
                <option value="shanghai">上海</option>
            </select>
            <br><br>
            
            其他信息
            <textarea v-model="userInfo.other"></textarea><br><br>
            <input type="checkbox" v-model="userInfo.agree">阅读并接受<a href="#">《阅读协议》</a>
            <button>提交</button>
        </form>
    </div>

    <script type="text/javascript">
        Vue.config.productionTip = false;  //阻止Vue在启动时生成 生产提示

        //创建Vue实例
        new Vue({
            el:'#root',
            data:{
                userInfo:{
                    account:'',
                    password:'',
                    age:18,
                    sex:'female',
                    hobby:[],
                    city:'shanghai',
                    other:'',
                    agree:''
                }
            },
            methods:{
                demo(){
                    console.log(JSON.stringify(this.userInfo));
                }
            }
        })
    </script>
</body>

</html>